$(function () {
  let layer = layui.layer
  let form = layui.form
  // 发布状态
  let pub_state = "已发布"
  // 1. 初始化图片裁剪器
  var $image = $('#image')
  // 2. 裁剪选项
  var options = {
    aspectRatio: 400 / 280,
    preview: '.img-preview'
  }
  // 3. 初始化裁剪区域
  $image.cropper(options)

  initCate()
  // 初始化富文本编辑器
  initEditor()

  // 定义加载文章分类的方法
  function initCate() {
    $.ajax({
      method: 'GET',
      url: '/my/article/cates',
      success: function (res) {
        if (res.status !== 0) {
          return layer.msg("初始化文章分类失败！")
        }
        let htmlStr = template("pub_cate", res);
        $("[name=cate_id]").html(htmlStr)
        form.render()
      }
    })
  }

  // 选择封面按钮的点击事件
  $("#btnChooseImage").on("click", function () {
    $("#coverFile").click()
  })

  // 监听 coverFile 的 change 事件
  $("#coverFile").on("change", function (e) {
    // 获取用户选择的文件
    let file = e.target.files
    // 判断用户是否选择了照片
    if (file.length == 0) {
      return
    }
    // 根据选择的文件，创建一个对应的URL地址
    let newImgURL = URL.createObjectURL(file[0])
    // 先`销毁`旧的裁剪区域，再`重新设置图片路径`，之后再`创建新的裁剪区域`：
    $image
      .cropper('destroy')      // 销毁旧的裁剪区域
      .attr('src', newImgURL)  // 重新设置图片路径
      .cropper(options)        // 重新初始化裁剪区域
  })

  // 存为草稿的点击事件
  $("#btnSave").on("click", function (e) {
    pub_state = "草稿"
  })

  // 表单的提交事件
  $("#form_pub").on("submit", function (e) {
    // 阻止默认提交行为
    e.preventDefault();
    // 基于form表单，快速创建一个 formData 对象
    let fd = new FormData($(this)[0])
    // 将文章的发布状态，存到 fd 中
    fd.append('state', pub_state)
    // 将裁剪后的图片，输出为文件
    $image
      .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
        width: 400,
        height: 280
      })
      .toBlob(function (blob) {       // 将 Canvas 画布上的内容，转化为文件对象
        // 得到文件对象后，进行后续的操作
        fd.append('cover_img', blob)
        // 发起Ajax请求
        publishArticle(fd)
      })
  })

  function publishArticle(fd){
    $.ajax({
      method: 'POST',
      url: '/my/article/add',
      data: fd,
      // 注意：如果向服务器提交的是 FormData 格式的数据，
      // 必须添加以下两个配置项
      contentType: false,
      processData: false,
      success: function(res) {
        if (res.status !== 0) {
          return layer.msg('发布文章失败！')
        }
        layer.msg('发布文章成功！')
        // 发布文章成功后，跳转到文章列表页面
        // location.href = '/article/art_list.html'
      }
    })
  }
})